<%--
  Created by IntelliJ IDEA.
  User: YQF
  Date: 2019/9/30
  Time: 22:57
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <meta charset="utf-8">
    <title>用户管理</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta http-equiv="Access-Control-Allow-Origin" content="*">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <%--<link rel="icon" href="favicon.ico">--%>
    <link rel="stylesheet" href="${pageContext.request.contextPath}/resources/layui/css/layui.css" media="all"/>
    <link rel="stylesheet" href="${pageContext.request.contextPath}/resources/css/public.css" media="all"/>
    <link rel="stylesheet" href="${pageContext.request.contextPath}/resources/layui_ext/dtree/dtree.css">
    <link rel="stylesheet" href="${pageContext.request.contextPath}/resources/layui_ext/dtree/font/dtreefont.css">
</head>
<body class="childrenBody">

<!-- 搜索条件开始 -->
<fieldset class="layui-elem-field layui-field-title" style="margin-top: 20px;">
    <legend>查询条件</legend>
</fieldset>
<form class="layui-form" method="post" id="searchFrm">

    <div class="layui-form-item">
        <div class="layui-inline">
            <label class="layui-form-label">用户姓名:</label>
            <div class="layui-input-inline" style="padding: 5px">
                <input type="text" name="realname" autocomplete="off" class="layui-input layui-input-inline"
                       placeholder="请输入用户名称" style="height: 30px;border-radius: 10px">
            </div>
        </div>
        <div class="layui-inline">
            <label class="layui-form-label">登陆名称:</label>
            <div class="layui-input-inline" style="padding: 5px">
                <input type="text" name="loginname" autocomplete="off" class="layui-input layui-input-inline"
                       placeholder="请输入用户登陆名称" style="height: 30px;border-radius: 10px">
            </div>
        </div>
        <div class="layui-inline">
            <label class="layui-form-label">用户地址:</label>
            <div class="layui-input-inline" style="padding: 5px">
                <input type="text" name="address" autocomplete="off" class="layui-input layui-input-inline"
                       placeholder="请输入用户地址" style="height: 30px;border-radius: 10px">
            </div>
        </div>
    </div>
    <div class="layui-form-item">
        <div class="layui-inline">
            <label class="layui-form-label">用户电话:</label>
            <div class="layui-input-inline" style="padding: 5px">
                <input type="text" name="phone" autocomplete="off" class="layui-input layui-input-inline"
                       placeholder="请输入用户电话" style="height: 30px;border-radius: 10px">
            </div>
        </div>
        <div class="layui-inline">
            <label class="layui-form-label">身份证号:</label>
            <div class="layui-input-inline" style="padding: 5px">
                <input type="text" name="identity" autocomplete="off" class="layui-input layui-input-inline"
                       placeholder="请输入身份证号" style="height: 30px;border-radius: 10px">
            </div>
        </div>
        <div class="layui-inline">
            <label class="layui-form-label">性别:</label>
            <div class="layui-input-inline">
                <input type="radio" name="sex" value="1" title="男">
                <input type="radio" name="sex" value="0" title="女">
            </div>
            <button type="button"
                    class="layui-btn layui-btn-normal layui-icon layui-icon-search layui-btn-radius layui-btn-sm"
                    id="doSearch" style="margin-top: 4px">查询
            </button>
            <button type="reset"
                    class="layui-btn layui-btn-warm layui-icon layui-icon-refresh layui-btn-radius layui-btn-sm"
                    style="margin-top: 4px">重置
            </button>
        </div>
    </div>

</form>

<!-- 数据表格开始 -->
<table class="layui-hide" id="userTable" lay-filter="userTable"></table>
<div id="userToolBar" style="display: none;">
    <button type="button" class="layui-btn layui-btn-sm layui-btn-radius" lay-event="add">增加</button>
    <button type="button" class="layui-btn layui-btn-danger layui-btn-sm layui-btn-radius" lay-event="deleteBatch">
        批量删除
    </button>
</div>
<div id="userBar" style="display: none;">
    <a class="layui-btn layui-btn-xs layui-btn-radius" lay-event="edit">编辑</a>
    <a class="layui-btn layui-btn-warm layui-btn-xs layui-btn-radius" lay-event="selectUserRole">分配角色</a>
    <a class="layui-btn layui-btn-normal layui-btn-xs layui-btn-radius" lay-event="resetUserPwd">重置密码</a>
    <a class="layui-btn layui-btn-danger layui-btn-xs layui-btn-radius" lay-event="del">删除</a>
</div>

<!-- 添加和修改的弹出层-->
<div style="display: none;padding: 20px" id="saveOrUpdateDiv">
    <form class="layui-form" lay-filter="dataFrm" id="dataFrm">
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">用户姓名:</label>
                <div class="layui-input-inline">
                    <input type="hidden" name="userid">
                    <input type="text" name="realname" lay-verify="required" placeholder="请输入用户姓名" autocomplete="off"
                           class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">登陆名称:</label>
                <div class="layui-input-inline">
                    <input type="text" name="loginname" lay-verify="required" placeholder="请输入登陆名称" autocomplete="off"
                           class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">身份证号:</label>
                <div class="layui-input-inline">
                    <input type="text" name="identity" placeholder="请输入身份证号" autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">用户地址:</label>
                <div class="layui-input-inline">
                    <input type="text" name="address" placeholder="请输入用户地址" autocomplete="off" class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">用户电话:</label>
                <div class="layui-input-inline">
                    <input type="text" name="phone" lay-verify="required|phone" placeholder="请输入用户电话" autocomplete="off"
                           class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">用户职位:</label>
                <div class="layui-input-inline">
                    <input type="text" name="position" placeholder="请输入用户职位" autocomplete="off" class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">用户性别:</label>
                <div class="layui-input-inline">
                    <input type="radio" name="sex" value="1" checked="checked" title="男">
                    <input type="radio" name="sex" value="0" title="女">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">是否可用:</label>
                <div class="layui-input-inline">
                    <input type="radio" name="available" value="1" checked="checked" title="可用">
                    <input type="radio" name="available" value="0" title="不可用">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: center;padding-right: 120px">
                <button type="button"
                        class="layui-btn layui-btn-normal layui-btn-md layui-icon layui-icon-release layui-btn-radius"
                        lay-filter="doSubmit" lay-submit="">提交
                </button>
                <button type="reset"
                        class="layui-btn layui-btn-warm layui-btn-md layui-icon layui-icon-refresh layui-btn-radius">重置
                </button>
            </div>
        </div>
    </form>
</div>

<%--用户分配角色的弹出层开始--%>
<div style="display: none;padding: 10px" id="selectUserRole">
    <table class="layui-hide" id="roleTable" lay-filter="roleTable"></table>
</div>


<script src="${pageContext.request.contextPath}/resources/layui/layui.js"></script>
<script type="text/javascript">
    var tableIns;
    layui.extend({
        dtree: '${pageContext.request.contextPath}/resources/layui_ext/dist/dtree'
    }).use(['jquery', 'layer', 'form', 'dtree', 'table'], function () {
        var $ = layui.jquery;
        var layer = layui.layer;
        var form = layui.form;
        var dtree = layui.dtree;
        var table = layui.table;
        //渲染表格
        tableIns = table.render({
            elem: '#userTable', //渲染的目标对象
            url: '${pageContext.request.contextPath}/user/loadAllUser.action', //数据接口地址
            title: '角色列表数据', //标题
            height: 'full-210',
            cellMinWidth: 100, //设置列最小默认宽度
            toolbar: '#userToolBar', //表格的头部工具栏
            page: true, //启动分页
            cols: [[
                {type: 'checkbox', fixed: 'left'},
                {field: 'userid', title: 'ID', align: 'center', width: '55'},
                {field: 'realname', title: '用户姓名', align: 'center', width: '110'},
                {field: 'loginname', title: '登录名称', align: 'center', width: '110'},
                {field: 'identity', title: '身份证', align: 'center', width: '200'},
                {field: 'phone', title: '手机号码', align: 'center', width: '140'},
                {field: 'address', title: '用户地址', align: 'center', width: '130'},
                {
                    field: 'sex', title: '用户性别', align: 'center', width: '90', templet: function (d) {
                        return d.sex == '1' ? '<font color=blue>男</font>' : '<font color=red>女</font>'
                    }
                },
                {
                    field: 'available', title: '是否可用', align: 'center', width: '90', templet: function (d) {
                        return d.available == '1' ? '<font color=blue>可用</font>' : '<font color=red>不可用</font>'
                    }
                },
                {fixed: 'right', title: '操作', toolbar: '#userBar', align: 'center', width: '300'}
            ]]
        });

        //模糊查询
        $("#doSearch").click(function () {
            //获取搜索框中的参数
            var param = $("#searchFrm").serialize();
            tableIns.reload({
                url: "${pageContext.request.contextPath}/user/loadAllUser.action?" + param,
                page: {curr: 1}
            })
        })

        //监听头部工具栏
        table.on("toolbar(userTable)", function (obj) {
            switch (obj.event) {
                case 'add':
                    openAddUser();
                    break;
                case 'deleteBatch':
                    deleteBatch();
                    break;
            }
        })


        var url;
        var mainIndex;

        //打开添加页面
        function openAddUser() {
            mainIndex = layer.open({
                type: 1,
                title: "添加用户",
                content: $("#saveOrUpdateDiv"),
                area: ['700px', '380px'],
                success: function (index) {
                    //清空表单数据
                    $("#dataFrm")[0].reset();
                    url = "${pageContext.request.contextPath}/user/addUser.action"

                }
            })
        }

        //保存
        form.on("submit(doSubmit)", function (obj) {
            //序列化表单数据
            var param = $("#dataFrm").serialize();
            $.post(url, param, function (obj) {
                layer.msg(obj.msg);
                //关闭弹出层
                layer.close(mainIndex);
                //刷新数据表格
                tableIns.reload();
            })
        })


        //监听行工具栏
        table.on('tool(userTable)', function (obj) {
            //获取当前行数据
            var data = obj.data;
            //获取事件
            var layEvent = obj.event;
            if (layEvent == 'del') {
                layer.confirm("您确认删除[" + data.realname + "]这个用户吗?", function (index) {
                    //向服务发送一个删除的请求
                    $.get("${pageContext.request.contextPath}/user/deleteUser.action", {userid: data.userid},
                        function (res) {
                            layer.msg(res.msg);
                            //刷新数据表格
                            tableIns.reload();
                        })
                })

            } else if (layEvent == 'edit') {
                openUpdateUser(data);
            } else if (layEvent == 'selectUserRole') {
                //分配角色
                openselectUserRole(data);
            } else if (layEvent == 'resetUserPwd') {
                //重置密码
                layer.confirm("您是否确认重置[" + data.realname + "]这个用户的密码?", function (index) {
                    $.post("${pageContext.request.contextPath}/user/resetUserPwd.action", {userid: data.userid}, function (res) {
                        layer.msg(res.msg)
                    })
                });
            }

        })

        //修改
        function openUpdateUser(data) {
            mainIndex = layer.open({
                type: 1,
                title: "修改用户",
                content: $("#saveOrUpdateDiv"),
                area: ['700px', '380px'],
                success: function (index) {
                    //回显数据
                    form.val("dataFrm", data);
                    url = "${pageContext.request.contextPath}/user/updateUser.action"

                }
            })
        }


        //批量删除角色
        function deleteBatch() {
            //得到我们选中的行
            var checkStatus = table.checkStatus('userTable');
            var data = checkStatus.data;
            var params = "";
            $.each(data, function (i, item) {
                if (i == 0) {
                    params += "ids=" + item.userid;
                } else {
                    params += "&ids=" + item.userid;
                }
            });
            layer.confirm("您真的确认删除这些用户吗?", function (index) {
                $.get("${pageContext.request.contextPath}/user/deleteBatchUser.action", params, function (res) {
                    layer.msg(res.msg);
                    //刷新表格
                    tableIns.reload();
                })
            })
        }

        //打开分配角色的弹出层
        function openselectUserRole(data){
            mainIndex = layer.open({
                type:1,
                title: '给['+data.realname+"]分配角色",
                content: $("#selectUserRole"),
                area:['700px','390px'],
                btnAlign: 'c',
                btn:['<div class="layui-icon layui-release">确认分配</div>','<div class="layui-icon layui-close">取消分配</div>'],
                yes: function (index, layero){
                    //得到选中的数据行
                    var checkStatus = table.checkStatus("roleTable");
                    var roleData = checkStatus.data;
                    var params = "userid="+data.userid;
                    $.each(roleData ,function (i,item){
                        params +="&ids="+item.roleid;
                    })
                    //保存操作
                    $.post("${pageContext.request.contextPath}/user/saveUserRole.action",params,function (obj){
                        layer.msg(obj.msg);
                        //关闭弹出层
                        layer.close(mainIndex);
                    })
                },

                success: function (index){
                    //渲染表格
                    var roleTableIns = table.render({
                        elem: '#roleTable',
                        url: '${pageContext.request.contextPath}/user/initUserRole.action?userid='+data.userid,
                        title: '角色列表',
                        cellMinWidth: 100,
                        cols: [[
                            {type: 'checkbox',fixed:'left'},
                            {field: 'roleid',title:'ID',align:'center'},
                            {field: 'rolename',title:'角色名称',align:'center'},
                            {field: 'roledesc',title:'角色描述',align:'center'},
                        ]]
                    })
                }
            })
        }


    })
</script>
</body>
</html>
